93 复原 ip 地址
有效 IP 地址 正好由四个整数(每个整数位于 0
到 255
之间组成,且不能含有前导 0
),整数之间用 '.'
分隔。
- 例如:
"0.1.2.201"
和"192.168.1.1"
是 有效 IP 地址,但是"0.011.255.245"
、"192.168.1.312"
和"192.168@1.1"
是 无效 IP 地址。
给定一个只包含数字的字符串 s
,用以表示一个 IP 地址,返回所有可能的有效 IP 地址,这些地址可以通过在 s
中插入 '.'
来形成。你 不能 重新排序或删除 s
中的任何数字。你可以按 任何 顺序返回答案。
示例 1:
** 输入:**s = "25525511135" 输出:["255.255.11.135","255.255.111.35"]
示例 2:
** 输入:**s = "0000" 输出:["0.0.0.0"]
示例 3:
** 输入:**s = "101023" 输出:["1.0.10.23","1.0.102.3","10.1.0.23","10.10.2.3","101.0.2.3"]
js
const restoreIpAddresses = (s) => {
const res = [];
// 复原从start开始的子串
const dfs = (subRes, start) => {
if (subRes.length == 4 && start == s.length) { // 片段满4段,且耗尽所有字符
res.push(subRes.join('.')); // 拼成字符串,加入解集
return; // 返不返回都行,指针已经到头了,严谨的说还是返回
}
if (subRes.length == 4 && start < s.length) { // 满4段,字符未耗尽,不用往下选了
return;
}
for (let len = 1; len <= 3; len++) { // 枚举出选择,三种切割长度
if (start + len - 1 >= s.length) return; // 加上要切的长度就越界,不能切这个长度
if (len != 1 && s[start] == '0') return; // 不能切出'0x'、'0xx'
const str = s.substring(start, start + len); // 当前选择切出的片段
if (len == 3 && +str > 255) return; // 不能超过255
subRes.push(str); // 作出选择,将片段加入subRes
dfs(subRes, start + len); // 基于当前选择,继续选择,注意更新指针
subRes.pop(); // 上面一句的递归分支结束,撤销最后的选择,进入下一轮迭代,考察下一个切割长度
}
};
dfs([], 0); // dfs入口
return res;
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27